<template>
  <input type="text" v-model="keywords" />
  <h3>{{ keywords }}</h3>
</template>

<script>
import { ref, customRef } from 'vue'
export default {
  name: 'App',
  setup() {
    // let keywords = ref('hello') //使用vue提供的ref
    let keywords = myRef('hello', 500) //使用自定义的ref

    // 自定义ref
    function myRef(value, delay) {
      let timer
      return customRef((track, trigger) => {
        return {
          get() {
            console.log(`有人读取了myRef容器数据，我把${value}给他了`)
            track() //告诉vue这个value值是需要被"追踪"的
            return value
          },
          set(newValue) {
            console.log(`有人修改了myRef容器数据，新的数据${newValue}给他了`)
            clearTimeout(timer)
            timer = setTimeout(() => {
              value = newValue
              trigger() //通知vue去重新解析模板
            }, delay)
          },
        }
      })
    }
    return {
      keywords,
    }
  },
}
</script>

<style></style>
